草庐IT

java - 测试字符串 Junit

全部标签

ruby-on-rails - 从字符串中删除重音符号/变音符号,同时保留其他特殊字符(尝试过 mb_chars.normalize 和 iconv)

有一个很similarquestion已经。其中一种解决方案使用如下代码:string.mb_chars.normalize(:kd).gsub(/[^x00-\x7F]/n,'').to_s这会产生奇迹,直到您注意到它还删除了空格、点、破折号,谁知道还有什么。我不太确定第一个代码是如何工作的,但是它可以去除仅重音吗?或者至少得到一份要保留的字符列表?我对正则表达式的了解很少,但我尝试了(无济于事):/[^\-x00-\x7F]/n#Soitwouldleavethedashalone我将要做这样的事情:string.mb_chars.normalize(:kd).gsub('-','

ruby - Ruby 1.8 和 1.9 的字符串哈希码是否相同?

我想用String.hash来生成hashcode,但是我担心如果过段时间我把版本从1.8升级到1.9,生成的hashcode也会改变。Ruby1.8和1.9的字符串哈希码是否相同? 最佳答案 幸运的是,答案很简单,因为他们没有:~$ruby1.8-e'p"helloworld".hash'444332266~$ruby1.9-e'p"helloworld".hash'-194819219如果您使用内置哈希方法,我建议您在构建过程中使用一个脚本来生成必要的哈希码。请注意,即使从一台机器到另一台机器,也不能保证它们是相同的。如果您需要

ruby - 如何将字符串拆分为多个单词的数组?

我有一个字符串,我正在使用.split('')将该字符串拆分为一个单词数组。我可以使用类似的方法将字符串拆分为2个单词的数组吗?返回一个数组,其中每个元素都是一个单词:words=string.split('')我希望返回一个数组,其中每个元素都是2个单词。 最佳答案 str='onetwothreefourfivesixseven'str.split.each_slice(2).map{|a|a.join''}=>["onetwo","threefour","fivesix","seven"]这也处理奇数个单词的情况。

ruby-on-rails - 如何在测试 Action 时将值放入闪存中

我正在尝试测试需要将值存储在闪存中的操作。defmy_actionifflash[:something].nil?redirect_toroot_pathifflash[:something]returnend#Dosomeotherstuffend在我的测试中,我做了类似的事情:before(:each)doflash[:something]="bob"endit"shoulddowhateverIhadcommentedoutabove"doget:my_action#Assertsomethingend我遇到的问题是flash在my_action中没有值。我猜这是因为实际上没有请

ruby-on-rails - 测试 Rails API 以使用 devise 进行注册。错误 : "Missing ' confirm_success_url' parameter.“

我正在尝试使用devise和devise_token_auth用于在我的应用中进行身份验证。我正在重写注册Controller,如下所示:moduleOverridesclassRegistrationsController:createdefsign_up_paramsparams.require(:user).permit(:email,:password,:password_confirmation,:name,:nickname)endendend我还使用swaggerdocsapi发送我的参数如下:swagger_api:createdosummary"Signupanewu

ruby - ruby 中带哈希的字符串插值

我的目标是用散列中的值替换字符串中的键。我是这样做的:"hello%{name},todayis%{day}"%{name:"Tim",day:"Monday"}如果字符串中的键在散列中丢失:"hello%{name},todayis%{day}"%{name:"Tim",city:"Lahore"}然后它会抛出一个错误。KeyError:key{day}notfound预期结果应该是:"helloTim,todayis%{day}"or"helloTim,todayis"有人可以指导我只替换匹配的键而不抛出任何错误吗? 最佳答案

ruby 字符串匹配忽略大小写

我正在尝试创建一个匹配查询,它从两个单词之间的字符串中选择文本。我似乎无法弄清楚如何使搜索不区分大小写。例如考虑文本:contents="catLoremipsumdolorsitamet,consecteturadipiscingelit.Donecblanditfeugiatmi,eulaciniaquamtincidunteu.Doneceleifendadipiscingneque,inportadolorvestibulumat.Curabituridelitvitaenuncfeugiatvarius.Maecenaseuismodeuismodmi,eublanditle

ruby - 正则表达式 - 匹配某些字符后的文本

我想从一些文本中抓取数据并将其转储到一个数组中。将以下文本作为示例数据:|ExampleData|Title:Thisisasampletitle|Content:Thisissamplecontent|Date:12/21/2012我目前正在使用以下正则表达式来抓取“冒号”字符后指定的数据:/((?=:).+)/不幸的是,这个正则表达式也抓取了冒号和冒号后面的空格。如何只抓取数据?此外,我不确定我这样做是否正确..但看起来好像外部括号导致匹配返回数组。这是parens的功能吗?编辑:我正在使用Rubular来测试我的正则表达式 最佳答案

ruby - 测试 ActiveSupport::TimeWithZone 对象的相等性

谁能解释一下d1为什么大于d2?他们是同一个该死的约会对象(或者至少在我看来他们是这样的)。Loadingdevelopmentenvironment(Rails3.0.8)ruby-1.9.2-p180:001>d1=Event.first.updated_at=>Thu,22Sep201102:24:28PDT-07:00ruby-1.9.2-p180:002>d2=Time.zone.parse("2011-09-22T02:24:28-07:00")=>Thu,22Sep201102:24:28PDT-07:00ruby-1.9.2-p180:003>d1.class=>Act

Ruby 实现是_numeric?对于字符串,需要更好的选择

我想验证字符串的“数值”(它不是事件记录模型中的属性)。我只需要它是一个有效的以10为底的正整数字符串。我这样做:classStringdefnumeric?#Checkifeverycharacterisadigit!!self.match(/\A[0-9]+\Z/)endendclassStringdefnumeric?#Checkisthereis*any*non-numericcharacter!self.match(/[^0-9]/)endend以下哪一个是更合理的选择?或者,还有其他更好的实现方式吗? 最佳答案 请确保使